<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
  </head>
  <body>
    <script>
      /* 
      ①定义dp数组和下标含义 dp[i][j]表示长度为i的字符串s是否为长度为j的字符串t的子序列
      ②状态转移方程  
      字符串比较问题都是比较尾序列。如果尾序列相同，那么则继续比较前面的
      if(s[i-1]==t[j-1]) dp[i][j]=dp[i-1][j-1]
      如果不同，那么删除t的尾序列继续比较前面的
      dp[i][j]=dp[i][j-1]
      */
      var isSubsequence = function (s, t) {
        let dp = new Array(s.length + 1).fill().map(() => new Array(t.length + 1).fill(0))
        for (let j = 0; j <= t.length; j++) {
          dp[0][j] = true
        }
        for (let i = 1; i <= s.length; i++) {
          for (let j = 1; j <= t.length; j++) {
            if (s[i - 1] == t[j - 1]) {
              dp[i][j] = dp[i - 1][j - 1]
            } else {
              dp[i][j] = dp[i][j - 1]
            }
          }
        }
        return dp[s.length][t.length]
      }
    </script>
  </body>
</html>
